## **Laboratory 2**

(Due date: **002/003**: October 8<sup>th</sup>, **004**: October 9<sup>th</sup>, **005**: October 10<sup>th</sup>)

## **OBJECTIVES**

- ✓ Use the Structural Description on VHDL.
- ✓ Test arithmetic circuits on an FPGA.

## **VHDL CODING**

✓ Refer to the <u>Tutorial: VHDL for FPGAs</u> for a list of examples.

## **FIRST ACTIVITY (100/100)**

- PROBLEM: Addition of four 4-bit unsigned numbers. The addition result requires 6 bits. This circuit can be built out of two 4-bit adders and one 5-bit adder as depicted in the figure ⇒
- The figure below depicts the internal architecture of the 4-bit adder and the 5-bit adder. The full adder circuit is also shown.





- ✓ Create a new Vivado Project. Select the XC7A100T-1CSG324 Artix-7 FPGA device.
- ✓ Write the VHDL code for the Adder of four 4-bit unsigned numbers. Use the Structural Description: Create a separate file for the Full Adder, the 4-bit adder, the 5-bit adder, and the top file (Adder of 4 4-bit numbers).
- ✓ Write the VHDL testbench to test the circuit to test the following cases:
  - $\mathbf{A}=0\times8$ ,  $\mathbf{B}=0\times\mathbb{E}$ ,  $\mathbf{C}=0\times\mathbb{F}$ ,  $\mathbf{D}=0\times9$   $\rightarrow$  S=101110
  - **A**=0xF, **B**=0xE, **C**=0x7, **D**=0x3  $\rightarrow$  S=100111
  - ♦ **A**=0xA, **B**=0x6, **C**=0x4, **D**=0x8  $\rightarrow$  S=011100
- ✓ Perform <u>Functional Simulation</u> and <u>Timing Simulation</u> of your design. **Demonstrate this to your TA**.
- ✓ I/O Assignment: Create the XDC file. Nexys-4 DDR: Use SW15-SW0 for the inputs, and LED5-LED0 for the outputs.
- Generate and download the bitstream on the FPGA and test. Demonstrate this to your TA.
- Submit (<u>as a .zip file</u>) the five generated files: VHDL code (4 files), VHDL testbench, and XDC file to Moodle (an assignment will be created). DO NOT submit the whole Vivado Project.

| FULL ADDER                                                                                                        | ×    |
|-------------------------------------------------------------------------------------------------------------------|------|
| $ \begin{array}{c} x & y \\ \downarrow & \downarrow \\ \hline FA & \\ \downarrow & \\ s & \\ \end{array} \equiv $ | cins |

| TA signature: |  |  |
|---------------|--|--|